<template>
	<scroll-view scroll-y="true" class="container" :data-theme="themeStyle">
		<!-- <view class="iconfont iconclose back-btn" @click="$util.goBack()"></view> -->
		<view class="header-wrap">
			<view class="title">注册</view>
			<view class="regisiter-agreement">
				<text class="color-tip">已有账号,</text>
				<text class="color-base-text" @click="toLogin">立即登录</text>
			</view>
		</view>
		<view class="body-wrap">
			<view class="form-wrap">
				<view class="input-wrap" v-show="registerMode == 'mobile'">
					<view class="content">
						<view class="area-code">+86</view>
						<input type="number" placeholder="仅限中国大陆手机号注册" placeholder-class="input-placeholder" class="input" maxlength="11" v-model="formData.mobile" />
					</view>
				</view>
				<view class="input-wrap" v-show="registerMode == 'mobile'">
					<view class="content"><input type="text" placeholder="请输入昵称" placeholder-class="input-placeholder" class="input" v-model="formData.name" /></view>
				</view>
				<view class="input-wrap" v-show="registerMode == 'mobile'">
					<view class="content"><input type="text" placeholder="请输入公司名称(选填)" placeholder-class="input-placeholder" class="input" v-model="formData.corporate_name" /></view>
				</view>
				<view class="input-wrap" v-show="registerMode == 'mobile'">
					<view class="content"><input type="text" placeholder="请输入邮箱号" placeholder-class="input-placeholder" class="input" v-model="formData.email" /></view>
				</view>
				<view class="input-wrap" v-show="registerMode == 'account'">
					<view class="content"><input type="text" placeholder="请输入账号" placeholder-class="input-placeholder" class="input" v-model="formData.account" /></view>
				</view>
				<view class="input-wrap">
					<view class="content"><input type="password" placeholder="请输入密码" placeholder-class="input-placeholder" class="input" v-model="formData.password" /></view>
				</view>
				<view class="input-wrap">
					<view class="content">
						<input type="password" placeholder="请确认密码" placeholder-class="input-placeholder" class="input" v-model="formData.rePassword" />
					</view>
				</view>
				<view class="input-wrap">
					<view class="content">
						<input type="text" placeholder="请输入图形验证码" placeholder-class="input-placeholder" class="input" v-model="formData.vercode" />
						<image :src="captcha.img" class="captcha" @click="getCaptcha"></image>
					</view>
				</view>
				<view class="input-wrap" v-show="registerMode == 'mobile'">
					<view class="content">
						<input type="text" placeholder="请输入短信动态码" placeholder-class="input-placeholder" class="input" v-model="formData.dynacode" />
						<view class="dynacode" :class="dynacodeData.seconds == 120 ? 'color-base-text' : 'color-tip'" @click="sendMobileCode">{{ dynacodeData.codeText }}</view>
					</view>
				</view>
			</view>
			<view class="login-mode-box">
				<text @click="switchRegisterMode" v-show="registerMode == 'mobile' && registerConfig.register.indexOf('username') != -1">使用用户名注册</text>
				<text @click="switchRegisterMode" v-show="registerMode == 'account' && registerConfig.register.indexOf('mobile') != -1">使用手机号注册</text>
			</view>
			<view class="btn_view"><button type="primary" @click="register" class="login-btn color-base-border color-base-bg">注册</button></view>
			<view class="regisiter-agreement">
				点击注册即代表您已同意
				<text class="color-base-text" @click="$u.route('/pages/index/text?type=fwxy')">《用户协议》</text>
				<text class="color-base-text" @click="$u.route('/pages/index/text?type=yszc')">《隐私政策》</text>
			</view>
		</view>

<!-- 		<view @touchmove.prevent>
			<uni-popup ref="registerPopup" type="center" :maskClick="false">
				<view class="conten-box">
					
					<view class="title c2">
						{{ regisiterAgreement.title }}
						<text class="iconfont iconclose" @click="toClose"></text>
					</view>
					<view class="con">
						<scroll-view scroll-y="true" class="con c1">
							<rich-text :nodes="regisiterAgreement.content"></rich-text>
						</scroll-view>
					</view>
				</view>
			</uni-popup>
		</view> -->

		<loading-cover ref="loadingCover"></loading-cover>
		<register-reward ref="registerReward"></register-reward>
	</scroll-view>
</template>

<script>
// import uniPopup from '@/components/uni-popup/uni-popup.vue';
import validate from 'common/js/validate.js';
import registerReward from '@/components/register-reward/register-reward.vue';
import auth from 'common/js/auth.js';
import globalConfig from '@/common/js/golbalConfig.js';

export default {
	components: {
		// uniPopup,
		registerReward
	},
	data() {
		return {
			allowRegister: true, // 是否允许注册
			registerMode: 'account',
			formData: {
				mobile: '',
				account: '',
				password: '',
				rePassword: '',
				vercode: '',
				dynacode: '',
				key: '',
				corporate_name:'',//公司名称
				email:'',//邮箱
				name:'',//昵称
			},
			regisiterAgreement: {
				// 注册协议
				title: '',
				content: ''
			},
			captcha: {
				// 验证码
				id: '',
				img: ''
			},
			isSub: false,
			back: '', // 返回页
			dynacodeData: {
				seconds: 120,
				timer: null,
				codeText: '获取短信动态码',
				isSend: false
			},
			registerConfig: {
				register: ''
			}
		};
	},
	mixins: [auth, globalConfig],
	onLoad(option) {
		if (option.back) this.back = option.back;
		this.getCaptcha();
		this.getRegisiterAggrement();

		if (uni.getStorageSync('authInfo')) {
			this.authInfo = uni.getStorageSync('authInfo');
		}
	},
	onShow() {
		// 刷新多语言
		this.$langConfig.refresh();
		// #ifdef MP
		this.getCode();
		// #endif
	},
	async onReady() {
		await this.getRegisterConfig();
		if (this.$refs.loadingCover) this.$refs.loadingCover.hide();
	},
	methods: {
		/**
		 * 切换注册方式
		 */
		switchRegisterMode() {
			this.registerMode = this.registerMode == 'mobile' ? 'account' : 'mobile';
		},
		/**
		 * 展示注册协议
		 */
		openPopup() {
			this.$refs.registerPopup.open();
		},
		/**
		 * 点击关闭协议
		 */
		toClose() {
			this.$refs.registerPopup.close();
		},
		/**
		 * 获取注册协议
		 */
		getRegisiterAggrement() {
			this.$api.sendRequest({
				url: '/api/register/aggrement',
				success: res => {
					if (res.code >= 0) {
						this.regisiterAgreement = res.data;
					}
				}
			});
		},
		/**
		 * 获取注册配置
		 */
		async getRegisterConfig() {
			let res = await this.$api.sendRequest({
				url: '/api/register/config',
				async: false
				});
				this.registerConfig = res.data.value;
				if (this.registerConfig.register == '') {
					this.$util.showToast({ title: '平台未启用注册!' });
					setTimeout(() => {
						this.$util.redirectTo('/pages/index/index/index', {}, 'tabbar');
					}, 1000);
				} else if (this.registerConfig.register.indexOf('username') != -1) {
					this.registerMode = 'account';
				} else {
					this.registerMode = 'mobile';
				}
				if (this.$refs.loadingCover) this.$refs.loadingCover.hide();
		},
		/**
		 * 获取验证码
		 */
		getCaptcha() {
			this.$api.sendRequest({
				url: '/api/captcha/captcha',
				data: {
					captcha_id: this.captcha.id
				},
				success: res => {
					if (res.code >= 0) {
						this.captcha = res.data;
						this.captcha.img = this.captcha.img.replace(/\r\n/g, '');
					}
				}
			});
		},
		/**
		 * 注册
		 */
		register() {
			if (this.registerMode == 'account') {
				var url = '/api/register/username';
				data = {
					username: this.formData.account,
					password: this.formData.password
				};
			} else {
				var url = '/api/register/mobile',
					data = {
						mobile: this.formData.mobile,
						key: this.formData.key,
						code: this.formData.dynacode,
						company_name:this.formData.corporate_name,
						nickname:this.formData.name,
						email:this.formData.email,
						password: this.formData.password
					};
			}
			if (this.captcha.id != '') {
				data.captcha_id = this.captcha.id;
				data.captcha_code = this.formData.vercode;
			}
			if (Object.keys(this.authInfo).length) {
				Object.assign(data, this.authInfo);
			}
			if (this.authInfo.avatarUrl) data.headimg = this.authInfo.avatarUrl;
			if (this.authInfo.nickName) data.nickname = this.authInfo.nickName;
			if (uni.getStorageSync('source_member')) data.source_member = uni.getStorageSync('source_member');

			if (this.verify(data)) {
				if (this.isSub) return;
				this.isSub = true;
				this.$api.sendRequest({
					url,
					data,
					success: res => {
						if (res.code >= 0) {
							uni.setStorage({
								key: 'token',
								data: res.data.token,
								success: () => {
									uni.removeStorageSync('loginLock');
									uni.removeStorageSync('unbound');
									uni.removeStorageSync('authInfo');

									if (this.$refs.registerReward.getReward()) {
										this.$util.showToast({
											title: '注册成功'
										});
										this.$refs.registerReward.open();
									} else {
										if (this.back != '') {
											this.$util.redirectTo(decodeURIComponent(this.back), {}, 'reLaunch');
										} else {
											this.$util.redirectTo('/pages/member/index/index', {}, 'reLaunch');
										}
									}
								}
							});
						} else {
							this.isSub = false;
							this.getCaptcha();
							this.$util.showToast({
								title: res.message
							});
						}
					},
					fail: res => {
						this.isSub = false;
						this.getCaptcha();
					}
				});
			}
		},
		verify(data) {
			let regConfig = this.registerConfig;
			
			// 手机号注册
			if (this.registerMode == 'mobile') {
				var rule = [
					{ name: 'mobile', checkType: 'required', errorMsg: '请输入手机号' }, 
					{ name: 'mobile', checkType: 'phoneno', errorMsg: '请输入正确的手机号' },
					{ name: 'nickname', checkType: 'required', errorMsg: '请输入昵称' },
					{ name: 'email', checkType: 'required', errorMsg: '请输入邮箱' },
					{ name: 'email', checkType: 'email', errorMsg: '请输入正确的邮箱' },
					{ name: 'code', checkType: 'required', errorMsg:'请输入短信验证码' }
				];
			}

			// 用户名注册
			if (this.registerMode == 'account') {
				var rule = [
					{ name: 'username', checkType: 'required', errorMsg: '请输入账号' }, 
					{ name: 'password', checkType: 'required', errorMsg: '请输入密码' },
				]
			}
			
			if (regConfig.pwd_len > 0) {
				rule.push({
					name: 'password',
					checkType: 'lengthMin',
					checkRule: regConfig.pwd_len,
					errorMsg: '密码长度不能小于' + regConfig.pwd_len + '位'
				});
			}
			if (regConfig.pwd_complexity != '') {
				let passwordErrorMsg = '密码需包含',
					reg = '';
				if (regConfig.pwd_complexity.indexOf('number') != -1) {
					reg += '(?=.*?[0-9])';
					passwordErrorMsg += '数字';
				}
				if (regConfig.pwd_complexity.indexOf('letter') != -1) {
					reg += '(?=.*?[a-z])';
					passwordErrorMsg += '、小写字母';
				}
				if (regConfig.pwd_complexity.indexOf('upper_case') != -1) {
					reg += '(?=.*?[A-Z])';
					passwordErrorMsg += '、大写字母';
				}
				if (regConfig.pwd_complexity.indexOf('symbol') != -1) {
					reg += '(?=.*?[#?!@$%^&*-])';
					passwordErrorMsg += '、特殊字符';
				}
				rule.push({
					name: 'password',
					checkType: 'reg',
					checkRule: reg,
					errorMsg: passwordErrorMsg
				});
			}
			if (this.formData.password != this.formData.rePassword) {
				this.$util.showToast({
					title: '两次密码不一致'
				});
				return false;
			}
			if (this.captcha.id != ''){
				rule.push({ name: 'captcha_code', checkType: 'required', errorMsg: '请输入图形验证码' });
			}
			var checkRes = validate.check(data, rule);
			if (checkRes) {
				return true;
			} else {
				this.$util.showToast({
					title: validate.error
				});
				return false;
			}
		},
		/**
		 * 去登录
		 */
		toLogin() {
			if (this.back)
				this.$util.redirectTo('/pages/login/login/login', {
					back: this.back
				});
			else this.$util.redirectTo('/pages/login/login/login');
		},
		/**
		 * 发送手机动态码
		 */
		sendMobileCode() {
			if (this.dynacodeData.seconds != 120) return;
			var data = {
				mobile: this.formData.mobile,
				captcha_id: this.captcha.id,
				captcha_code: this.formData.vercode
			};
			var rule = [
				{ name: 'mobile', checkType: 'required', errorMsg: '请输入手机号' },
				{ name: 'mobile', checkType: 'phoneno', errorMsg: '请输入正确的手机号' },
				{ name: 'captcha_code', checkType: 'required', errorMsg: '请输入图形验证码' }
			];
			var checkRes = validate.check(data, rule);
			if (!checkRes) {
				this.$util.showToast({ title: validate.error });
				return;
			}
			if (this.dynacodeData.isSend) return;
			this.dynacodeData.isSend = true;
			this.$api.sendRequest({
				url: '/api/register/mobileCode',
				data: data,
				success: res => {
					this.dynacodeData.isSend = false;
					if (res.code >= 0) {
						this.formData.key = res.data.key;

						if (this.dynacodeData.seconds == 120 && this.dynacodeData.timer == null) {
							this.dynacodeData.timer = setInterval(() => {
								this.dynacodeData.seconds--;
								this.dynacodeData.codeText = this.dynacodeData.seconds + 's后可重新获取';
							}, 1000);
						}
					} else {
						this.$util.showToast({ title: res.message });
					}
				},
				fail: () => {
					this.$util.showToast({ title: 'request:fail' });
					this.dynacodeData.isSend = false;
				}
			});
		}
	},
	watch: {
		'dynacodeData.seconds': {
			handler(newValue, oldValue) {
				if (newValue == 0) {
					clearInterval(this.dynacodeData.timer);
					this.dynacodeData = {
						seconds: 120,
						timer: null,
						codeText: '获取短信动态码',
						isSend: false
					};
				}
			},
			immediate: true,
			deep: true
		}
	}
};
</script>

<style lang="scss">
@import '../public/css/common.scss';
</style>
<style scoped>
	.conten-box{padding: 30rpx;}
	.c1{height: 60vh;}
	.c2{position: relative;text-align: center;font-size: 32rpx;}
	.c2 .iconfont{position: absolute;right: 0;top: 0;}
/deep/ .reward-popup .uni-popup__wrapper-box {
	background: none !important;
	max-width:88% !important;
	max-height: unset !important;
}
/deep/ .uni-popup__wrapper-box {
	max-width:88% !important;
}
</style>

